草庐IT

c++ - std::auto_ptr、delete[] 和泄漏

全部标签

javascript - 使用 socket.io 的内存泄漏

我发现当手动断开套接字时,套接字并没有在套接字io服务器端被完全破坏。我找到了thistopicongithub有用。当我在寻找一些阻止GC清理套接字的变量链接时,我在这里问一个问题。如果这里有人遇到同样的问题,这会很有帮助。无效的代码:socket.on('disconnect',function(){socket.removeAllListeners();});///...................socket.disconnect();但是,使用受限库字段的解决方法:deleteio.sockets[url];io.j=[]; 最佳答案

javascript - 使用 JQuery/JavaScript 导致内存泄漏的常见方法有哪些?

我的问题假设您正在创建一个将“长时间”显示的网页。我很好奇在这种情况下使用JQuery/JavaScript时会导致内存泄漏的一些常见问题是什么?例如,当您对元素集合调用$.remove()时,内存方面会发生什么情况?谢谢! 最佳答案 JavaScriptusesgarbagecollectiontoreclaimthememoryoccupiedbystrings,objects,arrays,andfunctionsthatarenolongerinuse.Thisfreesyou,theprogrammer,fromhavin

javascript - Chrome 在简单地添加和删除 SVG 元素时会泄漏内存

继续这个问题:Taskmanagershowsmemoryleak,butHeapsnapshotdoesn't我设法创建了一个非常简单的例子来说明这个漏洞,这里是完整的源代码:svgtestvarsvg;varinterval;varsvg;window.onload=function(){createSVG();start();}functionstart(){interval=setInterval(createElements,100);}functioncreateSVG(){vardiv=document.getElementById("svgdiv");div.inner

javascript - 内存泄漏 : Remaining elements in cache and data_user in AngularJs

我使用ng-repeat创建元素(有些是SVG标签,有些是简单的HTML)。在数据模型发生变化时——一个在新数据到达时重置的对象——总会有元素作为分离的DOM元素留下。他们是这样举行的:元素是data_user的一部分,它似乎是jquery的一部分。此问题发生在多个更改数据的地方。似乎观察者是问题所在,因为他们一直在引用自己的表情。元素被创建,例如像这样:.directive('svgGraphic',['$compile',function($compile){return{restrict:'E',replace:false,link:function(scope,element,

javascript - 是否可以修复第三方广告的内存泄漏?

我在使用GoogleDFP广告的Playlist.com上不断发生内存泄漏-打开标签页,它一直使用越来越多的内存(仅当启用广告时)。可在此处找到重现泄漏的示例测试页:http://dl.dropboxusercontent.com/u/6278910/ad-memory-leak.html.我们这边有什么办法可以帮助减少泄漏吗?显然,从经济上讲,关闭广告不是一个可行的解决方案。编辑:您可以在Chrome中打开开发者工具并尝试内存时间轴-每次加载广告时,它们都会占用更多内存。 最佳答案 这是可能的,尝试重新加载iframe以在删除它之

javascript - Arguments 对象是否泄漏?

假设我有这个草率模式函数,它(出于某种奇怪的原因)将其arguments对象返回给调用者:functionexample(a,b/*...*/){varc=//someprocessingreturnarguments;}存储调用结果(vard=example();)会阻止example的变量环境(包含a,b、c等)免于被垃圾回收?Argumentsobject的内部setter和getter可能仍然引用它,就像从闭包返回的函数一样。演示:functionexample(a,b){varc=Array(1000).fill(0);//somelargeobjectreturn{args

javascript - 三.JS | PerObject-Blur,我可以使用哪些技术来优化 GLSL/C 代码?

更新2我已经使用THREE.js实现了自定义属性,影响来自顶点着色器中与位置属性对齐的每次传递,这是代码最少的最佳解决方案。Iwilladdtheexamplelater更新1此方法将alpha设置为受边界框内速度范围影响的顶点。我需要提示来处理GLSL代码重复pervertex,这对我来说有点奇怪?我应该使用函数吗?怎么办?https://jsfiddle.net/LeroyRon/uep9t1v1/#&togetherjs=MjBnNMFQFl反正我有这个://for.xif(position.x>0.0){if(velocityPosition.x+(velocities.x*s

javascript - 在将 Squire.js 与 RequireJS 和 Mocha 一起使用时,如何避免引入全局泄漏?

我正在使用Backbone和Backbone.Marionette编写单页JavaScript应用程序。我正在使用AMD模块和RequireJS来帮助组织我的代码和管理依赖项。我也在使用Mocha作为我的TDD/BDD测试框架。一切正常,直到我想使用Sinon.JS引入stub、模拟和spy。经过大量搜索,我在testframeworksintheRequireJSwiki上找到了一个页面和Squire.js,这似乎很适合我的需要。但是,当我尝试使用Squire.js加载模块时,Mocha突然报告模块依赖项的全局泄漏。如果我直接使用Require.JS加载模块,则没有泄漏报告。例如,下

JavaScript 内存泄漏 (Node.js/Restify/MongoDB)

更新4:通过在函数外部实例化restify客户端(参见controllers/messages.js)并在每次请求后调用global.gc(),内存增长率似乎已降低很多(每10秒约500KB)。然而,内存使用量仍在不断增长。更新3:遇到这篇文章:https://journal.paul.querna.org/articles/2011/04/05/openssl-memory-use/可能值得注意的是,我将HTTPS与Restify结合使用。更新2:将下面的代码更新为当前状态。我试过用Express替换Restify。遗憾的是,这没有任何区别。似乎链末端的api调用(restify->

javascript - 使用适当的 GC 删除 DOM 节点(无泄漏)

问题添加节点,同时从DOM中删除旧节点,不会从内存中丢弃旧节点。(至少不是全部,没有明显的原因)。如何看待这种情况(你已经知道了,但无论如何..)右键单击输出区域并使用Chrome开发人员工具进行检查。单击时间轴选项卡,然后单击左上角的圆圈(点)开始录制。现在点击body元素,它将开始每300ms添加和删除项目(删除的节点应该被垃圾收集)。停止记录,将数据采样区域扩展到最大,您将在屏幕的下半部分看到绿色的节点。预期的图形将上下波动(其中向下表示节点已被GC正确丢弃)。测试页面这2个测试页面非常原始。当然,在现实生活中,开发人员使用生成大量文本的模板,这些文本应转换为DOM并注入(inj